## MP4 Design Checkpoint

November 2nd, 2020

Alex Vetsavong Mohan Li Peter Kircher



## **Control ROM**

The prefixes for the control signals only indicate where they will be used, to be consistent with the datapath diagram. In implementation, all the signals will be set at the ID stage, where the Control ROM will reside, and passed down the pipeline.

```
module control rom(
input rv32i_opcode opcode,
input logic [2:0] funct3,
input logic [6:0] funct7,
output logic mem_read, mem_write,
output logic [3:0] mem byte enable,
output immmux:immmux_sel_t immmux_sel,
output alumux::alumux1_sel_t alumux1_sel,
output alumux::alumux2_sel_t alumux2_sel,
output regfilemux::regfilemux_sel_t regfilemux_sel,
output cmpmux::cmpmux_sel_t cmpmux_sel,
output alu_ops aluop,
output branch funct3 t cmpop,
output logic load_regfile
);
case(opcode)
    lui:
    auipc:
```

```
jal:
jalr:
         (uses the I-type encoding)
br:
load:
store:
```

```
imm:
    case(funct3)
        slt:
        sltu:
        sr:
        default:
    endcase
regs:
    case(funct3)
        slt:
        sltu:
```

When implemented, ideally instead of individual signals, a typedef struct will be defined for readability in the port instantiations.

## IF/ID Register: Example for Pipeline Registers

```
module IF.ID(
    input clk, rst, load,
    input logic [31:0] IF.mem_rdata,
    input logic [31:0] IF.PC,
    output logic [31:0] ID.mem_rdata,
    output logic [31:0] ID.PC,
    output logic [2:0] funct3,
    output logic [6:0] funct7,
    output rv32i_opcode opcode,
    output logic [31:0] i_imm,
    output logic [31:0] s_imm,
    output logic [31:0] b_imm,
    output logic [31:0] u_imm,
    output logic [31:0] j_imm,
    output logic [4:0] rs1,
    output logic [4:0] rs2,
    output logic [4:0] rd
);
logic [31:0] pc, mem_rdata;
assign ID.PC = pc;
assign ID.mem_rdata = mem_rdata;
IR IF.ID_IR(.*); // will explicitly instantiate ports in actual code
always_ff(@posedge clk) begin
    mem_rdata <= IF.mem_rdata;</pre>
    pc <= IF.PC;</pre>
end
endmodule
```

A basic look at what could be passed into the IF/ID pipelining register. Here, we take advantage of the given IR code to break it up into several registers and make the code more readable.

A similar approach will be taken with the rest of the pipeline registers, based on our datapath design.